home *** CD-ROM | disk | FTP | other *** search
/ CU Amiga Super CD-ROM 15 / CU Amiga Magazine's Super CD-ROM 15 (1997)(EMAP Images)(GB)[!][issue 1997-10].iso / CUCD / Graphics / Ghostscript / source / iref.h < prev    next >
C/C++ Source or Header  |  1997-04-19  |  14KB  |  374 lines

  1. /* Copyright (C) 1989, 1995, 1996 Aladdin Enterprises.  All rights reserved.
  2.   
  3.   This file is part of Aladdin Ghostscript.
  4.   
  5.   Aladdin Ghostscript is distributed with NO WARRANTY OF ANY KIND.  No author
  6.   or distributor accepts any responsibility for the consequences of using it,
  7.   or for whether it serves any particular purpose or works at all, unless he
  8.   or she says so in writing.  Refer to the Aladdin Ghostscript Free Public
  9.   License (the "License") for full details.
  10.   
  11.   Every copy of Aladdin Ghostscript must include a copy of the License,
  12.   normally in a plain ASCII text file named PUBLIC.  The License grants you
  13.   the right to copy, modify and redistribute Aladdin Ghostscript, but only
  14.   under certain conditions described in the License.  Among other things, the
  15.   License requires that the copyright notice and this notice be preserved on
  16.   all copies.
  17. */
  18.  
  19. /* iref.h */
  20. /* Object structure and type definitions for Ghostscript */
  21.  
  22. #ifndef iref_INCLUDED
  23. #  define iref_INCLUDED
  24.  
  25. /* The typedef for object references */
  26. typedef struct ref_s ref;
  27.  
  28. /* The typedef for packed object references.  This is opaque here: */
  29. /* the details are in packed.h. */
  30. typedef ushort ref_packed;
  31. #define log2_sizeof_ref_packed arch_log2_sizeof_short
  32. #define sizeof_ref_packed (1 << log2_sizeof_ref_packed)
  33.  
  34. /*
  35.  * Define the object types.
  36.  * The types marked with @ are composite and hence use the a_space field;
  37.  * objects of all other types must have a_space cleared.
  38.  * The types marked with ! behave differently in the interpreter
  39.  * depending on whether they are executable or literal.
  40.  * The types marked with + use the read/write/execute
  41.  * attributes; the rest only use the executable attribute.
  42.  * The types marked with # use the size field.
  43.  */
  44. typedef enum {
  45.  
  46. /*
  47.  * Type 0 must be left unassigned, so that the type (and type_attrs)
  48.  * of a valid ref will never be zero.  This speeds up simultaneous
  49.  * type/space checking in def (see dstack.h for details) and a similar
  50.  * check in ref_save (see store.h for details).  We may as well use
  51.  * type 0 for t__invalid, which will never appear in a real ref.
  52.  *
  53.  * The "invalid" type is only used in a few special places: the guard
  54.  * entries at the bottom of the o-stack that detect stack underflow,
  55.  * and (eventually) the ref that the cached value pointer in names points to
  56.  * if the binding isn't known.  It never appears on a stack or in a
  57.  * program-visible data structure.
  58.  */
  59.  
  60.     t__invalid,        /*    (no value) */
  61.     t_boolean,        /*    value.boolval */
  62.     t_dictionary,        /* @ +  value.pdict */
  63.     t_file,            /* @!+# value.pfile, uses size for id */
  64.  
  65. /*
  66.  * The 4 array types must be kept together, and must start at
  67.  * a multiple of 4, for the sake of r_is_array and r_is_proc (see below).
  68.  */
  69.  
  70. #define _t_array_span 4
  71.     t_array,        /* @!+# value.refs */
  72.         /* The following are the two implementations of */
  73.         /* packed arrays. */
  74.     t_mixedarray,        /* @!+# value.packed */
  75.     t_shortarray,        /* @!+# value.packed */
  76.       t_unused_array_,    /*    (an unused array type) */
  77.  
  78. /*
  79.  * t_[a]struct is an "umbrella" for other types that are represented by
  80.  * allocated objects (structures).  Objects of these types are composite
  81.  * and hence use the a_local attribute.  The type name is taken from
  82.  * the allocator template for the structure.  t_astruct objects use the
  83.  * access attributes; t_struct objects do not.  Neither t_struct nor
  84.  * t_astruct objects use the size.
  85.  *
  86.  * t_struct is currently used for the following PostScript types:
  87.  *    condition, lock.
  88.  * We could use it for fontIDs, except that they may have subclasses.
  89.  * Eventually it will also be used for the new 'device' type.
  90.  * t_astruct is currently used for the following PostScript types:
  91.  *    gstate.
  92.  *
  93.  * The 2 structure types must be kept together, and must start at
  94.  * a multiple of 2, for the sake of r_has_stype (see below).
  95.  */
  96.  
  97. #define _t_struct_span 2
  98.     t_struct,        /* @    value.pstruct */
  99.     t_astruct,        /* @ +    value.pstruct */
  100.  
  101. /*
  102.  * We now continue with individual types.
  103.  */
  104.     t_fontID,        /* @    value.pstruct */
  105.     t_integer,        /*    value.intval */
  106.     t_mark,            /*        (no value) */
  107. /*
  108.  * Name objects use the a_space field because they really are composite
  109.  * objects internally.
  110.  */
  111.     t_name,            /* @! # value.pname, uses size for index */
  112.     t_null,            /*  ! # (value.opproc, uses size for mark */
  113.                 /*        type, on e-stack only) */
  114. /*
  115.  * Operator objects use the a_space field because they may actually be
  116.  * disguised procedures.  (Real operators always have a_space = 0.)
  117.  */
  118.     t_operator,        /* @! # value.opproc, uses size for index */
  119.     t_real,            /*    value.realval */
  120.     t_save,            /*      value.saveid, see isave.h for why */
  121.                 /*        this isn't a t_struct */
  122.     t_string,        /* @!+# value.bytes */
  123. /*
  124.  * The following are extensions to the PostScript type set.
  125.  * When adding new types, be sure to edit the table in gs_init.ps
  126.  * (==only operator), the printing routine in idebug.c, the dispatches
  127.  * in igc.c, igcref.c, and interp.c, obj_eq in iutil.c, restore_check_stack
  128.  * in zvmem.c, and also type_name_strings and type_print_strings below.
  129.  */
  130.     t_device,        /* @ +   value.pdevice */
  131.     t_oparray,        /* @! #  value.const_refs, uses size */
  132.                 /*         for index */
  133.     t_next_index    /*** first available index ***/
  134. } ref_type;
  135. /*
  136.  * The interpreter uses types starting at t_next_index for representing
  137.  * a few high-frequency operators.
  138.  * Since there are no operations specifically on operators,
  139.  * there is no need for any operators to check specifically for these
  140.  * types.  The r_btype macro takes care of the conversion when required.
  141.  */
  142. /*extern const int tx_next_index;*/        /* in interp.c */
  143. /*
  144.  * Define the types that use the access attributes (w/r/x).
  145.  */
  146. #define case_types_with_access\
  147.   case t_dictionary: case t_file:\
  148.   case t_array: case t_mixedarray: case t_shortarray:\
  149.   case t_astruct: case t_string: case t_device
  150. /*
  151.  * Define the types that use the size field.
  152.  * (The extended types used by the interpreter also use the size field.)
  153.  * We don't include t_null here, because it only uses the size field
  154.  * on the e-stack.
  155.  */
  156. #define case_types_with_size\
  157.   case t_array: case t_mixedarray: case t_shortarray:\
  158.   case t_file: case t_name: case t_operator: case t_string:\
  159.   case t_oparray
  160. /*
  161.  * Define the type names for debugging printout.
  162.  * All names must be the same length, so that columns will line up.
  163.  */
  164. #define type_print_strings\
  165.   "INVL","bool","dict","file",\
  166.   "arry","mpry","spry","u?ry",\
  167.   "STRC","ASTR",\
  168.   "font","int ","mark","name","null",\
  169.   "oper","real","save","str ",\
  170.   "devc","opry"
  171. /*
  172.  * Define the type names for the type operator.
  173.  */
  174. #define type_name_strings\
  175.   0,"booleantype","dicttype","filetype",\
  176.   "arraytype","packedarraytype","packedarraytype","arraytype",\
  177.   0,0,\
  178.   "fonttype","integertype","marktype","nametype","nulltype",\
  179.   "operatortype","realtype","savetype","stringtype",\
  180.   "devicetype","operatortype"
  181.  
  182. /*
  183.  * The following factors affect the encoding of attributes:
  184.  *
  185.  *    - The packed array format requires the high-order bits of the
  186.  *      type/attributes field to be 0.  (see packed.h)
  187.  *
  188.  *    - The interpreter wants the type, executable bit, and execute
  189.  *      permission to be adjacent, and in that order from high to low.
  190.  *
  191.  *    - Type testing is most efficient if the type is in a byte by itself.
  192.  *
  193.  * The layout given below results in the most efficient code overall.
  194.  */
  195.  
  196. /* Location attributes. */
  197. /* Note that these are associated with the *location*, not with the */
  198. /* ref that is *stored* in that location. */
  199. #define l_mark 1            /* mark for garbage collector */
  200. #define l_new 2                /* stored into since last save */
  201. /* Attributes visible at the PostScript language level. */
  202. /* Reserve bits for VM space information (defined in ivmspace.h). */
  203. #define r_space_bits 2
  204. #define r_space_shift 2
  205. #define a_write 0x10
  206. #define a_read 0x20
  207. #define a_execute 0x40
  208. #define a_executable 0x80
  209. #define a_readonly (a_read+a_execute)
  210. #define a_all (a_write+a_read+a_execute)
  211. #define r_type_shift 8
  212. #define r_type_bits 6
  213.  
  214. /* Define the attribute names for debugging printout. */
  215. /* Each entry has the form <mask, value, character>. */
  216. typedef struct attr_print_mask_s {
  217.     ushort mask;
  218.     ushort value;
  219.     char print;
  220. } attr_print_mask;
  221. #define attr_print_flag(m,c)\
  222.   {m,m,c},{m,0,'-'}
  223. #define attr_print_space(v,c)\
  224.   {((1<<r_space_bits)-1)<<r_space_shift,v,c}
  225. #define attr_print_masks\
  226.   attr_print_flag(l_mark,'m'),\
  227.   attr_print_flag(l_new,'n'),\
  228.   attr_print_space(avm_foreign,'F'),\
  229.   attr_print_space(avm_system,'S'),\
  230.   attr_print_space(avm_global,'G'),\
  231.   attr_print_space(avm_local,'L'),\
  232.   attr_print_flag(a_write,'w'),\
  233.   attr_print_flag(a_read,'r'),\
  234.   attr_print_flag(a_execute,'x'),\
  235.   attr_print_flag(a_executable,'e'),\
  236.   attr_print_flag(0x4000,'?'),\
  237.   attr_print_flag(0x8000,'?')
  238.   
  239. /* Abstract types */
  240. typedef struct dict_s dict;
  241. typedef struct name_s name;
  242. #ifndef stream_DEFINED
  243. #  define stream_DEFINED
  244. typedef struct stream_s stream;
  245. #endif
  246. #ifndef gx_device_DEFINED
  247. #  define gx_device_DEFINED
  248. typedef struct gx_device_s gx_device;
  249. #endif
  250. #ifndef obj_header_DEFINED
  251. #  define obj_header_DEFINED
  252. typedef struct obj_header_s obj_header_t;
  253. #endif
  254. /* We duplicate the definition of os_ptr (a.k.a. s_ptr) here */
  255. /* so that we can have an accurate typedef for op_proc */
  256. /* without having to drag in istack.h and ostack.h. */
  257. typedef int (*op_proc_p)(P1(ref _ds *));
  258. /* real_opproc is a holdover.... */
  259. #define real_opproc(pref) ((pref)->value.opproc)
  260.  
  261. /* Object reference */
  262. /*
  263.  * Note that because of the way packed arrays are represented,
  264.  * the type_attrs member must be the first one in the ref structure.
  265.  */
  266. struct tas_s {
  267.     ushort type_attrs;
  268.     ushort rsize;
  269. };
  270. struct ref_s {
  271.  
  272.     struct tas_s tas;
  273.  
  274. #define r_size(rp) ((rp)->tas.rsize)
  275. #define r_inc_size(rp,inc) ((rp)->tas.rsize += (inc))
  276. #define r_dec_size(rp,dec) ((rp)->tas.rsize -= (dec))
  277. #define r_set_size(rp,siz) ((rp)->tas.rsize = (siz))
  278. /* type_attrs is a single element for fast dispatching in the interpreter */
  279. #if r_type_shift == 8
  280. #  if arch_is_big_endian
  281. #    define r_type(rp) (((const byte *)&((rp)->tas.type_attrs))[sizeof(ushort)-2])
  282. #  else
  283. #    define r_type(rp) (((const byte *)&((rp)->tas.type_attrs))[1])
  284. #  endif
  285. #  define r_has_type(rp,typ) (r_type(rp) == (typ))
  286. #else
  287. #  define r_type(rp) ((rp)->tas.type_attrs >> r_type_shift)
  288. #  define r_has_type(rp,typ) r_has_type_attrs(rp,typ,0)    /* see below */
  289. #endif
  290. /* A special macro for testing arrayhood. */
  291. #define r_is_array(rp) _r_has_masked_type_attrs(rp,t_array,_t_array_span,0)
  292. #define r_set_type(rp,typ) ((rp)->tas.type_attrs = (typ) << r_type_shift)
  293. #define r_btype(rp)\
  294.  ((rp)->tas.type_attrs >= (t_next_index << r_type_shift) ?\
  295.   t_operator : r_type(rp))
  296. #define r_type_xe_shift (r_type_shift - 2)
  297. #define type_xe_(tas) ((tas) >> r_type_xe_shift)    /* internal use only */
  298. /*
  299.  * The r_type_xe macro is used in (and only in) the main interpreter loop,
  300.  * where its rp operand may be a ref_packed, not necessarily aligned as
  301.  * strictly as a full-size ref.  The DEC C compiler, and possibly others,
  302.  * may compile code assuming that rp is ref-aligned.  Therefore, we
  303.  * explicitly cast the pointer to a less-strictly-aligned type.
  304.  */
  305. #define r_type_xe(rp) type_xe_(*(const ushort *)&(rp)->tas.type_attrs)
  306. #define type_xe_value(t,xe) type_xe_(((t) << r_type_shift) + (xe))
  307. #define r_type_attrs(rp) ((rp)->tas.type_attrs)    /* reading only */
  308. #define r_has_attrs(rp,mask) !(~r_type_attrs(rp) & (mask))
  309. #define r_has_masked_attrs(rp,attrs,mask)\
  310.   ((r_type_attrs(rp) & (mask)) == (attrs))
  311. #define r_has_attr(rp,mask1)        /* optimize 1-bit case */\
  312.    (r_type_attrs(rp) & (mask1))
  313. /* The following macro is not for external use. */
  314. #define _r_has_masked_type_attrs(rp,typ,tspan,mask)\
  315.  (((rp)->tas.type_attrs &\
  316.    ((((1 << r_type_bits) - (tspan)) << r_type_shift) + (mask))) ==\
  317.   (((typ) << r_type_shift) + (mask)))
  318. #define r_has_type_attrs(rp,typ,mask)\
  319.   _r_has_masked_type_attrs(rp,typ,1,mask)
  320. /* A special macro for testing procedurehood. */
  321. #define r_is_proc(rp)\
  322.   _r_has_masked_type_attrs(rp,t_array,_t_array_span,a_execute+a_executable)
  323. #define r_set_attrs(rp,mask) ((rp)->tas.type_attrs |= (mask))
  324. #define r_clear_attrs(rp,mask) ((rp)->tas.type_attrs &= ~(mask))
  325. #define r_store_attrs(rp,mask,attrs)\
  326.   ((rp)->tas.type_attrs = ((rp)->tas.type_attrs & ~(mask)) | (attrs))
  327. #define r_copy_attrs(rp,mask,sp)\
  328.   r_store_attrs(rp,mask,(sp)->tas.type_attrs & (mask))
  329. #define r_set_type_attrs(rp,typ,mask)\
  330.   ((rp)->tas.type_attrs = ((typ) << r_type_shift) + (mask))
  331. /* Macros for t_[a]struct objects. */
  332. #define r_is_struct(rp) _r_has_masked_type_attrs(rp,t_struct,_t_struct_span,0)
  333. #define r_has_stype(rp,mem,styp)\
  334.   (r_is_struct(rp) && gs_object_type(mem, (rp)->value.pstruct) == &styp)
  335. #define r_ptr(rp,typ) ((typ *)((rp)->value.pstruct))
  336. #define r_set_ptr(rp,ptr) ((rp)->value.pstruct = (obj_header_t *)(ptr))
  337.  
  338.     union v {            /* name the union to keep gdb happy */
  339.         long intval;
  340.         ushort boolval;
  341.         float realval;
  342.         ulong saveid;
  343.         byte *bytes;
  344.         const byte *const_bytes;
  345.         ref *refs;
  346.         const ref *const_refs;
  347.         name *pname;
  348.         const name *const_pname;
  349.         dict *pdict;
  350.         const dict *const_pdict;
  351.         const ref_packed *packed;
  352.         op_proc_p opproc;
  353.         struct stream_s *pfile;
  354.         struct gx_device_s *pdevice;
  355.         obj_header_t *pstruct;
  356.     } value;
  357. };
  358.  
  359. /* Define the size of a ref. */
  360. #define arch_sizeof_ref sizeof(ref)
  361. /* Define the required alignment for refs. */
  362. /* We assume all alignment values are powers of 2. */
  363. #define arch_align_ref_mod\
  364.  (((arch_align_long_mod - 1) | (arch_align_float_mod - 1) |\
  365.    (arch_align_ptr_mod - 1)) + 1)
  366.  
  367. /* Define the maximum size of an array or a string. */
  368. /* The maximum array size is determined by the fact that */
  369. /* the allocator cannot allocate a block larger than max_uint. */
  370. #define max_array_size (max_ushort & (max_uint / (uint)arch_sizeof_ref))
  371. #define max_string_size max_ushort
  372.  
  373. #endif                    /* iref_INCLUDED */
  374.